

# Министерство науки и высшего образования Российской Федерации Федеральное государственное бюджетное образовательное учреждение высшего образования

## «Московский государственный технический университет имени Н.Э. Баумана

(национальный исследовательский университет)» (МГТУ им. Н.Э. Баумана)

ФАКУЛЬТЕТ «Информатика и системы управления»

КАФЕДРА «Программное обеспечение ЭВМ и информационные технологии»

# Отчет по лабораторной работе №1 по дисциплине "Архитектура ЭВМ"

| Тема Проектирование систем на кристалле на основе ПЛИС |
|--------------------------------------------------------|
| Студент Костев Д.                                      |
| <b>Группа</b> <u>ИУ7-51Б</u>                           |
| Оценка (баллы)                                         |
| Преподаватель                                          |

## Оглавление

| 1        | Цели лабораторной работы:                                                                | 2        |
|----------|------------------------------------------------------------------------------------------|----------|
| <b>2</b> | <b>Аналитическая часть</b> 2.1 Функциональная схема разрабатываемой системы на кристалле | <b>3</b> |
| 3        | Практическая часть         3.1 Модуль в QSYS          3.2 Создание проекта Nios2         |          |
| 4        | Вывод                                                                                    | 9        |
| Лi       | итература                                                                                | 10       |

### 1 Цели лабораторной работы:

**Цель работы:** изучение основ построения микропроцессорных систем на ПЛИС. В ходе работы необходимо ознакомиться с принципами построения систем на кристалле (СНК) на основе ПЛИС, получить навыки проектирования СНК в САПР Altera Quartus II, выполнить проектирование и верификацию системы с использованием отладочного комплекта Altera DE1Board.

#### 2 Аналитическая часть

# 2.1 Функциональная схема разрабатываемой системы на кристалле.



Рис. 2.1: Функциональная схема разрабатываемой системы на кристалле

Система на кристалле состоит из следующих блоков:

- Микропроцессорное ядро Nios II/е выполняет функции управления системой.
- Внутренняя оперативная память СНК, используемая для хранения программы управления и данных.
- Системная шина Avalon обеспечивает связность всех компонентов системы.
- Блок синхронизации и сброса обеспечивает обработку входных сигналов сброса и синхронизации и распределение их в системе. Внутренний сигнал сброса синхронизирован и имеет необходимую для системы длительность.
- Блок идентификации версии проекта обеспечивает хранение и выдачу уникального идентификатора версии, который используется программой управления при инициализации системы.

| • | Контр | оллер | UART | обеспечив | ает прис | ем и пере, | дачу инс | формации | по инте | рфейсу | RS232. |
|---|-------|-------|------|-----------|----------|------------|----------|----------|---------|--------|--------|
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |
|   |       |       |      |           |          |            |          |          |         |        |        |

### 3 Практическая часть

#### 3.1 Модуль в QSYS

- 1. Был создан новый модуль Qsys.
- 2. Установлена частота внешнего сигнала синхронизации 50 000 000 Гц.
- 3. Добавлен в проект модуль синхронизируемого микропроцессорного ядра Nios2.
- 4. Добавлен в проект модуль ОЗУ программ и данных.
- 5. Добавлены компоненты Avalon System ID, Avalon UART.
- 6. Создана сеть синхронизации и сбоса системы.
- 7. Сигналы ТХ и RX экспортированы во внешние порты.
- 8. Назначены базовые адреса устройств.

Итог выполненных действий показан на рисунке 3.1. На рисунке 3.2 показана таблица распределения адресов.

:uments\kate\nios.qsys)



Рис. 3.1: Модуль QSYS

| System Contents Address Map    | Clock Settings Project Settings Instance Parameters System Inspector HDL Example Generation |
|--------------------------------|---------------------------------------------------------------------------------------------|
|                                | nios2_qsys_0.data_master nios2_qsys_0.instruction_master                                    |
| nios2_qsys_0.jtag_debug_module | 0x8800 - 0x8fff 0x8800 - 0x8fff                                                             |
| onchip_memory2_0.s1            | 0x4000 - 0x6003 0x4000 - 0x6003                                                             |
| sysid_qsys_0.control_slave     | 0x9048 - 0x904f                                                                             |
| uart_0.s1                      | 0x9020 - 0x903f 0x9020 - 0x903f                                                             |
|                                |                                                                                             |
|                                |                                                                                             |

Рис. 3.2: Таблица распределения адресов

#### 3.2 Создание проекта Nios2

В файл helloworldsmall.c был добавлен код эхо-программы приема-передачи по интерфейсу RS232, представленный на листинге 3.1. Также был создан образ ОС HAL с драйверами устройств, используемых в аппаратном проекте.

Листинг 3.1: Функция нахождения расстояния Левенштейна рекурсивно

```
|#include "sys/alt stdio.h"
  int main()
3
  {
      char ch;
      alt putstr("Hello from System on Chip\n");
      alt putstr("Send any character\n");
      /* Event loop never exits. */
      while (1) {
          ch=alt getchar();
10
          alt putchar(ch);
11
12
      return 0;
13
14
```

После успешной сборки и выполнения код программы был доработан: были добавлены строки, передающие по UART значение SystemID в виде четырех байт символов в ASCII формате.. Результат доработки представлен на листинге 3.2.

Листинг 3.2: Функция нахождения расстояния Левенштейна рекурсивно

```
|\#include "sys/alt stdio.h"
2 #include "system.h"
3 #include "altera avalon sysid qsys.h"
4 #include "altera avalon sysid qsys regs.h"
  int main()
  {
      char ch;
      alt putstr("Hello from System on Chip\n");
      alt putstr("Send any character\n");
      int id = IORD ALTERA AVALON SYSID QSYS ID(SYSID QSYS 0 BASE);
11
      char a [6];
12
      int i = 1;
13
      while (id)
14
15
           a[4 - i] = '0' + id \% 10;
           id /= 10;
17
           i++;
18
19
      a[4] = ' \ n';
20
      a[5] = ' \ 0';
21
      for (int i = 0; i < 5; i++)
22
           alt putchar(a[i]);
23
```

```
/* Event loop never exits. */
while (1)

ch=alt_getchar();
    alt_putchar(ch);
}

return 0;
```

Результат выполнения программы показан на рисунке 3.3. **Замечание:** программа не собралась на моем компьютере из-за отсутствия драйверов, в моем же варианте было бы число 5109.



Рис. 3.3: Результат выполнения программы

## 4 Вывод

В ходе данной лабораторной работы были изучены основы построения микропроцессорных систем на ПЛИС, получены навыки проектирования СНК в САПР Altera Quartus II, также были выполнены проектирование и верификация системы с использованием отладочного комплекта Altera DE1Board.

## Литература

1. Методические указания к ЛР1 по ЭВМ. URL: https://e-learning.bmstu.ru/iu6/pluginfile.php/16762/nresource/content/2/ЭВМ-ЛР-Разработка-СнК.pdf, 01.10.2021